#include<bits/stdc++.h>
using namespace std;
typedef long long ll;

void solve(){
    int n,k;
    cin>>n>>k;
    vector<ll> a(n),b(k);
    for(int i=0;i<n;i++)cin>>a[i];
    for(int i=0;i<k;i++)cin>>b[i];

    sort(a.begin(),a.end(),greater<ll>());
	sort(b.begin(),b.end());
	int t=0;
	ll res=0;
	for(int i=0;i<k;i++){
		if(t==n)break;
		for(int j=0;j<b[i];j++){
			// cout<<t<<' ';
			if(j!=b[i]-1)res+=a[t];
			t++;
			if(t==n)break;
		}
	}
	for(int i=t;t<n;t++){
		res+=a[i];
	}
	cout<<res<<'\n';
}

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0),cout.tie(0);
    int t=1;
    cin>>t;
    while(t--){
        solve();
    }
    return 0;
}